البرمجة

التدويل والتوطين في .NET

جدول المحتوى

التدويل (Internationalization) والتوطين (Localization) في .NET: مقاربة شاملة لبرمجة التطبيقات العالمية

تُعد مفاهيم التدويل (I18N) والتوطين (L10N) من الركائز الأساسية في تطوير البرمجيات الحديثة التي تستهدف جمهورًا متنوعًا من مختلف اللغات والثقافات. ففي ظل العولمة الرقمية واتساع نطاق المستخدمين، أصبح من الضروري أن تتمكن التطبيقات من التأقلم مع اللغات والأنظمة الثقافية المختلفة. ومن بين الأطر التي أولت هذا الجانب أهمية كبيرة نجد منصة .NET من مايكروسوفت، والتي وفرت أدوات ومكتبات قوية تسهّل على المطورين تنفيذ عمليات التدويل والتوطين بطريقة مرنة وقابلة للتوسع.

يهدف هذا المقال إلى تقديم شرح موسّع لمفاهيم التدويل والتوطين في بيئة .NET، مع استعراض آليات التنفيذ، والممارسات المُوصى بها، والمكونات المعمارية التي تدعم تطوير تطبيقات متعددة اللغات والثقافات.


أولاً: التمييز المفاهيمي بين التدويل والتوطين

التدويل (Internationalization)

يشير التدويل إلى عملية إعداد التطبيق منذ البداية بحيث يدعم بسهولة ترجمته وتكييفه مع لغات وثقافات متعددة دون الحاجة إلى تغييرات جذرية في الكود البرمجي. يتضمن ذلك فصل المحتوى القابل للترجمة عن منطق التطبيق، واستخدام صيَغ مرنة للتواريخ والأرقام، وتجنب التضمينات الصريحة للغة معينة.

التوطين (Localization)

في المقابل، التوطين هو العملية التي يتم من خلالها تخصيص التطبيق ليعمل ضمن ثقافة أو لغة معينة. يشمل التوطين ترجمة النصوص، وتنسيق التواريخ والأرقام والعملات، وتعديل التخطيطات حسب اتجاه اللغة (مثل دعم الاتجاه من اليمين إلى اليسار للغات كالعربية والعبرية)، وغيرها من التعديلات الثقافية.


ثانياً: البنية التحتية للتدويل والتوطين في .NET

توفر منصة .NET إطارًا متكاملًا يدعم التدويل والتوطين عبر عدة طبقات:

  1. نظام الموارد (Resources)

  2. الثقافات (Cultures)

  3. المترجمات ResourceManager

  4. المكوّنات المعمارية مثل Satellite Assemblies


ثالثاً: نظام الموارد في .NET

ملفات الموارد RESX

في .NET، يتم فصل النصوص القابلة للترجمة داخل ملفات موارد ذات امتداد .resx. كل ملف يحتوي على أزواج المفتاح-القيمة للنصوص المعروضة في واجهة المستخدم. على سبيل المثال:

  • Resources.resx: يحتوي على النصوص الافتراضية (عادةً باللغة الإنجليزية)

  • Resources.ar.resx: يحتوي على ترجمات اللغة العربية

  • Resources.fr.resx: يحتوي على ترجمات اللغة الفرنسية

يتم تحميل الملف المناسب تلقائيًا حسب ثقافة المستخدم أثناء تشغيل التطبيق.

إدارة الموارد ResourceManager

تقوم فئة ResourceManager بتحميل القيم المناسبة بناءً على الثقافة الحالية للتطبيق. عند تغيير Thread.CurrentThread.CurrentUICulture، يتم توجيه التطبيق لاستخدام ملفات الموارد المتوافقة.

csharp
Thread.CurrentThread.CurrentUICulture = new CultureInfo("ar"); string greeting = Resources.HelloMessage;

رابعاً: الثقافات (Cultures) في .NET

الثقافة Culture في .NET تُستخدم لتحديد اللغة، التنسيق الزمني، تنسيق الأرقام، العملة، وترتيب الفرز في التطبيق. يتم تمثيل الثقافة باستخدام الكائن CultureInfo.

أنواع الثقافات

  1. الثقافة المحايدة (Neutral Culture): مثل “ar” أو “en”

  2. الثقافة المحددة (Specific Culture): مثل “ar-EG” (العربية – مصر) أو “en-US” (الإنجليزية – الولايات المتحدة)

استخدام CultureInfo

csharp
CultureInfo culture = new CultureInfo("fr-FR"); Thread.CurrentThread.CurrentCulture = culture; Thread.CurrentThread.CurrentUICulture = culture;

خامساً: توطين واجهات المستخدم في تطبيقات .NET

1. توطين تطبيقات Windows Forms

يمكن استخدام خاصية Localizable داخل المصمم (Designer) لجعل النموذج يدعم التوطين. عند تفعيل هذه الخاصية وتحديد لغة، يتم إنشاء ملف FormName.Lang.resx تلقائيًا.

2. توطين تطبيقات ASP.NET

في تطبيقات ASP.NET، يتم استخدام ملفات الموارد ضمن مجلد App_GlobalResources أو App_LocalResources.

مثال على تحميل نص من المورد:

csharp
"Label1" runat="server" Text="<%$ Resources:MyResources, WelcomeMessage %>" />

3. توطين تطبيقات Blazor

في Blazor، يدعم التوطين باستخدام الحزمة Microsoft.Extensions.Localization، ويفضل استخدام ملفات JSON أو RESX بالتزامن مع IStringLocalizer.


سادساً: Satellite Assemblies

تُستخدم الأقراص التابعة Satellite Assemblies لعزل ملفات الموارد الخاصة بكل لغة عن ملفات التجميع الأساسية. يتم إنشاؤها تلقائيًا أثناء البناء عند وجود ملفات resx متعددة، وتُخزّن في مجلدات فرعية تحمل اسم الثقافة.

تنظيم الملفات:

python
bin\ ├── MyApp.exe ├── ar\ │ └── MyApp.resources.dll ├── fr\ │ └── MyApp.resources.dll

سابعاً: التحقق من التوافق الثقافي

من الضروري اختبار التطبيقات باستخدام ثقافات مختلفة للتأكد من:

  • عدم حدوث أخطاء في تحميل الموارد

  • التوافق مع التنسيقات الزمنية والعددية

  • دعم الاتجاهات النصية (RTL أو LTR)

الجدول التالي يوضح بعض الفروق المهمة بين الثقافات:

الثقافة تنسيق التاريخ تنسيق الرقم اتجاه النص
en-US MM/dd/yyyy 1,234.56 من اليسار إلى اليمين
ar-SA dd/MM/yyyy ١٬٢٣٤٫٥٦ من اليمين إلى اليسار
fr-FR dd/MM/yyyy 1 234,56 من اليسار إلى اليمين

ثامناً: دعم الاتجاه من اليمين إلى اليسار RTL

تعد خاصية دعم اتجاه النص من اليمين إلى اليسار ضرورية عند التوطين للغات مثل العربية والفارسية. في Windows Forms مثلًا، يمكن تفعيل ذلك من خلال:

csharp
this.RightToLeft = RightToLeft.Yes; this.RightToLeftLayout = true;

في ASP.NET، يمكن ضبط الاتجاه باستخدام الوسوم:

html
<html dir="rtl" lang="ar">

تاسعاً: استراتيجيات إدارة الترجمات

في المشاريع الكبيرة، قد تتعدد الملفات والمكونات التي تحتاج إلى توطين. لذلك يُنصح باستخدام استراتيجيات منظمة:

  • استخدام ملفات ترجمة منفصلة لكل مكون أو صفحة

  • الاستفادة من أدوات إدارة الترجمات مثل PoEdit أو Crowdin

  • التكامل مع خدمات الترجمة الآلية ولكن مع مراجعة بشرية

  • اعتماد مراجعة دورية للترجمات للتأكد من صحتها وسياقها


عاشراً: التدويل في الوقت الفعلي والتوطين الديناميكي

قد تتطلب بعض التطبيقات تغيير اللغة أثناء التشغيل دون إعادة تشغيل التطبيق. يدعم .NET هذا السيناريو بشرط تحميل النصوص باستخدام ResourceManager وليس تعيينها في وقت التصميم.

خطوات التوطين الديناميكي:

  1. تغيير CurrentUICulture وCurrentCulture

  2. إعادة تحميل عناصر الواجهة

  3. استخدام واجهات برمجية (APIs) لإعادة تعيين النصوص


حادي عشر: الحماية من الأخطاء المرتبطة بالثقافات

قد تؤدي الثقافات المختلفة إلى أخطاء وقت التشغيل، مثل:

  • فشل في تحويل النص إلى تاريخ

  • اختلاف في تنسيقات النقطة العشرية

  • مشاكل في الترتيب الأبجدي

حلول مقترحة:

  • استخدام TryParse بدلاً من Parse

  • الاعتماد على CultureInfo.InvariantCulture في تخزين البيانات

  • اختبار وحدات الإدخال/الإخراج تحت ثقافات متعددة


ثاني عشر: ممارسات موصى بها للتدويل والتوطين

  • لا تستخدم نصوصًا ثابتة في الكود

  • استخدم موارد منفصلة للتواريخ والأرقام والصيغ

  • خطط للتدويل منذ بداية المشروع

  • اختبر الواجهات باستخدام لغات بطول كلمات مختلفة

  • استخدم رموز مميزة (tokens) لتجميع الجمل بدلًا من استخدام نصوص مترجمة حرفيًا


ثالث عشر: التدويل في تطبيقات الجوال باستخدام .NET MAUI

يوفر .NET MAUI دعمًا أصليًا للتوطين عبر ملفات RESX، مع قدرة على التبديل بين اللغات وتشغيل التطبيقات باستخدام الموارد المناسبة لكل نظام تشغيل.

مثال على التوطين في MAUI:

  1. إنشاء ملفات Resources.resx وResources.ar.resx

  2. استخدام IStringLocalizer لعرض النصوص

  3. ضبط الثقافة باستخدام:

csharp
CultureInfo.CurrentUICulture = new CultureInfo("ar");

المراجع


هذا العرض المفصل يعكس مدى أهمية التدويل والتوطين في تصميم التطبيقات الحديثة باستخدام .NET، ويوضح الأدوات والأساليب التي تجعل هذه المهمة أكثر قابلية للإدارة والتوسع، مما يتيح للتطبيقات أن تتحدث لغة مستخدميها، حرفيًا وثقافيًا.